import { memo } from 'react'
import { Card, Form, Input, Button } from 'antd'
import logo from '@/assets/logo.png'
import { LoginPage } from './style'
import { login } from '@/store/modules/userStore'
import { useDispatch } from 'react-redux'
import { useNavigate } from 'react-router-dom'
import { message } from 'antd'

const Login = memo(() => {
  const dispatch = useDispatch()
  const navigate = useNavigate()

  const onFinish = async formValue => {
    await dispatch(login(formValue))
    navigate('/')
    message.success('登录成功')
  }

  return (
    <LoginPage>
      <Card className="login-container">
        <img className="login-logo" src={logo} alt="" />
        {/* 登录表单 */}
        <Form
          validateTrigger={['onBlur']}
          onFinish={onFinish}
          initialValues={{
            mobile: '13800000002',
            code: '246810'
          }}
        >
          <Form.Item
            name="mobile"
            rules={[
              { required: true, message: '请输入手机号' },
              {
                pattern: /^1[3-9]\d{9}$/,
                message: '手机号码格式不对'
              }
            ]}
          >
            <Input size="large" placeholder="请输入手机号" />
          </Form.Item>
          <Form.Item
            name="code"
            rules={[{ required: true, message: '请输入验证码' }]}
          >
            <Input size="large" placeholder="请输入验证码" />
          </Form.Item>
          <Form.Item>
            <Button type="primary" htmlType="submit" size="large" block>
              登录
            </Button>
          </Form.Item>
        </Form>
      </Card>
    </LoginPage>
  )
})

Login.displayName = 'Login'
export default Login
